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PRET TMTNARY AMENDMENT 

Assistant Commissioner for Patents 
Washington, D.C. 20231 

Please enter the following amendments and remarks prior to examination of this 
continuation application: 



TN THE DRAWINGS 

Applicant has attached a red-lined drawing showing a proposed amendment to Figure 9. 
Applicant will provide revised formal drawings following the Examiner's approval of the 
proposed changes. 

TN THE SPECTFTCATTON 

On page 1, line 7, before "This invention" please insert --This apphcation is a 
continuation of U.S. Serial No. 08/457,650 filed June 1, 1995, which is a continuation-in-part of 
U.S. Serial No, 08/386,894 filed February 10, 1995, now U.S. Patent No. 5,610,864, which is a 
continuation-in-part of U.S. Serial No. 08/370,761 filed December 23, 1994, now U.S. Patent 
No. 5,526,320.- 

At page 28, line 9, before "Memory control circuit 118" please insert -A power up 
detection circuit 134 may be coupled to microprocessor 1 12 and to a power supply 136. Power 
up detection circuit 134 is responsive to a signal from power supply 136 to cause microprocessor 
1 12 to access a nonvolatile memory device to receive information enabling microprocessor 134 
to detect the mode of a memory device of memory 124 and to program memory control circuit 
1 18 in accordance with the memory device mode.-- 
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TN THE CL A IMS 

After adding claims 26-37 as provided below, please cancel claims 1-25 without 
prejudice or disclaimer. 

26, [New] A system, comprising: 

a bus for transferring information; 

a memory, coupled to the bus, comprised of a memory device which is interchangeably of 
a mode selected from the group consisting of burst extended data out mode and 
fast page mode, the memory having a first set of access control signal timing 
requirements for the burst extended data out mode and a second set of access 
control signal timing requirements for the fast page mode; 

a programmable memory controller, coupled to the bus and to the memory, capable of 

providing the first set of access control signal timing requirements and the second 
set of access control signal timing requirements to the memory; and 

a processor, coupled to the bus and the memory controller, responsive to at least 

information from the memory to program the memory controller to provide a set 
of access control signals to the memory in accordance with the memory device 
mode, wherein the information from the memory includes data read from the 
memory device. 

27. [New] The system of claim 26, further comprising: 
a power supply; and 

a power up detection circuit coupled to the processor and to the power supply, the power 
up detection circuit responsive to a signal from the power supply to cause the 
processor to detect the memory device mode and to program the memory 
controller in accordance with the memory device mode. 
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28. [New] A system, comprising: 

a bus for transferring information; 

a memory, coupled to the bus, comprised of a memory device which is interchangeably of 
a mode selected from the group consisting of burst extended data out mode and 
fast page mode, the memory having a first set of access control signal timing 
requirements for the burst extended data out mode and a second set of access 
control signal timing requirements for the fast page mode; 

a progranmiable memory controller, coupled to the bus and to the memory, capable of 

providing the first set of access control signal timing requirements and the second 
set of access control signal timing requirements to the memory; 

a processor, coupled to the bus and the memory controller; 

a power supply; and 

a power up detection circuit coupled to the processor and to the power supply, the power 
up detection circuit responsive to a signal from the power supply to cause the 
processor to detect the memory device mode and to program the memory 
controller; 

wherein the processor is responsive to at least information from the memory to program 
the memory controller to provide a set of access control signals to the memory in 
accordance with the memory device mode, wherein the information from the 
memory includes data read from the memory device. 



Page 3 

Dkt: 303.164US3 



29. [New] A system, comprising: 

a bus for transferring information; 

a memory, coupled to the bus, comprised of a memory device which is interchangeably of 
a mode selected from the group consisting of burst extended data out mode and 
extended data out mode, the memory having a first set of access control signal 
timing requirements for the burst extended data out mode and a second set of 
access control signal timing requirements for the extended data out mode; 
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a programmable memory controller, coupled to the bus and to the memory, capable of 

providing the first set of access control signal timing requirements and the second 
set of access control signal timing requirements to the memory; and 

a processor, coupled to the bus and the memory controller, responsive to at least 

information from the memory to program the memory controller to provide a set 
of access control signals to the memory in accordance with the memory device 
mode, wherein the information from the memory includes data read from the 
memory device. 

30. [New] The system of claim 29, fiirther comprising: 
a power supply; and 

a power up detection circuit coupled to the processor and to the power supply, the power 
up detection circuit responsive to a signal from the power supply to cause the 
processor to detect the memory device mode and to program the memory 
controller in accordance with the memory device mode. 

31. [New] A system, comprising: 

a bus for transferring information; 

a memory, coupled to the bus, comprised of a memory device which is interchangeably of 
a mode selected from the group consisting of burst extended data out mode and 
extended data out mode, the memory having a first set of access control signal 
timing requirements for the burst extended data out mode and a second set of 
access control signal timing requirements for the extended data out mode; 

a programmable memory controller, coupled to the bus and to the memory, capable of 

providing the first set of access control signal timing requirements and the second 
set of access control signal timing requirements to the memory; 

a processor, coupled to the bus and the memory controller; 

a power supply; and 
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a power up detection circuit coupled to the processor and to the power supply, the power 
up detection circuit responsive to a signal from the power supply to cause the 
processor to detect the memory device mode and to program the memory 
controller; 

wherein the processor is responsive to at least information from the memory to program 
the memory controller to provide a set of access control signals to the memory in 
accordance with the memory device mode, wherein the information from the 
memory includes data read from the memory device. 



32. [New] A system, comprising: 

a bus for transferring information; 

a memory, coupled to the bus, comprised of a memory device having a first operation 
mode and a second operation mode, wherein the memory has a first set of access 
control signals for operation in the first operation mode and a second set of access 
control signals for operation in the second operation mode; 

a programmable memory controller, coupled to the bus and to the memory, capable of 
providing the first set of access control signals and the second set of access 
control signals to the memory; and 

a processor, coupled to the bus and the memory controller, responsive to at least 

information from the memory to program the memory controller to provide the 
first set of access control signals to the memory at a first time and the second set 
of access control signals to the memory at a second time. 



33. [New] The system of claim 32, fiirther comprising: 
a power supply; and 

a power up detection circuit coupled to the processor and to the power supply, the power 
up detection circuit responsive to a signal from the power supply to cause the 
processor to detect the memory device mode and to program the memory 
controller in accordance with the memory device mode. 
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34. [New] A system, comprising: 

a bus for transferring information; 

a memory, coupled to the bus, comprised of a memory device having a first operation 

mode and a second operation mode, wherein the memory has a first set of access 
control signals for operation in the first operation mode and a second set of access 
control signals for operation in the second operation mode; 

a programmable memory controller, coupled to the bus and to the memory, capable of 
providing the first set of access control signals and the second set of access 
control signals to the memory; 

a processor, coupled to the bus and the memory controller; 

a power supply; and 

a power up detection circuit coupled to the processor and to the power supply, the power 
up detection circuit responsive to a signal from the power supply to cause the 
processor to detect the memory device mode and to program the memory 
controller; 

wherein the processor is responsive to at least information from the memory to program 
the memory controller to provide the first set of access control signals to the 
memory at a first time and the second set of access control signals to the memory 
at a second time. 



35. [New] A system, comprising: 
a memory controller; and 
a memory, wherein the memory comprises: 

a first bank of burst access memory coupled to the memory controller to receive a 

plurahty of access control signals; and 
a second bank comprised of a memory type selected from the group consisting of 
extended data out memory and fast page mode memory, wherein the 
second bank is coupled to the memory controller to receive the plurahty of 
access control signals, further wherein the memory controller drives the 
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access control signals in a first mode to provide access to the first bank, 
still further wherein the memory controller drives the access control 
signals in a second mode to provide access to the second bank. 

36. [New] The system of claim 35, wherein the memory type of the second bank is 
interchangeable. 

37. [New] A system, comprising: 
a memory controller; and 

a memory, wherein the memory comprises: 

a first bank and a second bank, wherein the first bank and the second bank are 
each independently interchangeably of a memory type selected from the 
group consisting of a first type of memory and a second type of memory, 
further wherein the memory controller controls access of the first bank and 
second bank in accordance with a first set of requirements for the first type 
of memory and a second set of requirements for the second type of 
memory. 

R EMARKS 

Applicant notes that U.S. Patent No. 5,610,864 has been used as a primary reference in 
support of rejection under 35 U.S.C. § 103(a) in related case U.S. Apphcation Serial 
No, 09/139924. Applicant further notes that the present case claims priority to U.S. Patent 
No. 5,610,864. Accordingly, U.S. Patent No. 5,610,864 cannot be used in support of rejection 
except as provided by 35 U.S.C. § 102(e). 

As provided in Pub. Law 106-1 13, enacted November 29, 1999, a reference quaUfying 
only under 35 U.S.C. § 102(e) cannot be used in support of a rejection under 35 U.S.C. § 103 
where the subject matter of the reference and the claimed invention were, at the time the 
invention was made, owned by the same person or subject to an obligation of assignment to the 
same person. See, 35 U.S.C, § 103(c). Applicant asserts that the subject matter of U.S. Patent 
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No. 5,610,864 and the present case were either owned by the same person or subject to an 
obhgation of assignment to the same person at the time the invention was made. Accordingly, 
AppUcant suggests that U.S. Patent No. 5,610,864 cannot be used in support of rejection of the 
present claims under 35 U.S.C, § 103(a), 

Proposed Amendment to the Drawings 

Applicant has amended Figure 9 to include a power up detection circuit 134 and a power 
supply 136. Applicant respectfully submits that support for the amendment is found, by way of 
example and without limitation, in claim 3 as originally filed. Applicant further notes that the 
proposed amendment to Figure 9 was previously submitted in an Amendment and Response in 
U.S. Apphcation Serial No. 09/139,924, and was approved by Examiner Hong Kim in Paper 
No. 10 of that case. Applicant respectfully submits that the proposed amendment does not 
constitute new matter. 

Amendment to the Specification 

Apphcant has amended the Specification to incorporate subject matter of original claim 3 
into the body of the Specification. In estabUshing a disclosure, an apphcant may rely not only on 
the description and drawings as filed but also on the original claims if their content justifies it. 
See MPEP § 608.01(1). Original claim 3 recited in part, "a power supply; and a power up 
detection circuit coupled to said microprocessor and to said power supply, said power up 
detection circuit responsive to a signal from said power supply to cause said microprocessor to 
access said nonvolatile memory device to receive information enabling said microprocessor to 
detect the type of memory device and to program the memory controller in accordance with the 
type of memory device said memory is comprised of" Apphcant respectfully submits that 
reliance on the content of original claim 3 for incorporation into the body of the Specification is 
justified, and that such incorporation does not constitute new matter. Applicant notes that the 
proposed amendment to the Specification was previously submitted in an Amendment and 
Response in U.S. Application Serial No. 09/139,924, and was not objected to by Examiner Hong 
Kim in Paper No. 10 of that case. 
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CO NCLUS IO N 



Applicant presents claims 26-37 for examination on the merits. The Examiner is invited 
to telephone Applicant's attorney 612-371-2103 to facilitate prosecution of this application. 

If necessary, please charge any additional fees or credit overpayment to Deposit Account 



No, 19-0743. 



Respectfully submitted, 
BRETT L. WILLIAMS 
By their Representatives, 

SCHWEGMAN, LUNDBERG, WOESSNER KLUTH, P.A. 
P.O. Box 2938 
Minneapolis, MN 55402 
(612) 371-2103 



Date 





Thomas W. Leiiei 
Reg. No. 40,697 



CERTIFrCATK UNDER 37 CFR /. W : 

"Express Mail" mailing label number: F,T4Q060RQ:^RIIS 

I hereby certify that this paper or fee is being deposited with the United States Postal S« 
37 CFR 1 .10 on the date indicated above and is addressed to the Assistant Commissif 




Date nf Deposit: Fehniary 22. 2000 
;e "Express Mail Post Office to Addressee" service under 
\for Patents, wLhington, D.C. 20231. 



Name 



Signatul 



8/10 





4 

Inventor(s): Williams 

SYSTEM ADAPTED TO RECEIVE MULTIPLE MEMORY TYPES, AND 
METHOD FOR DETERMINING A TYPE OF MEMORY PRESENT 

5 FTRLD OF THE INVENTION 

This invention relates to system architectures adapted to receive 
multiple types of memory devices and methods of determining the type of 
memory present. 

10 

RACKGROUND OF THE INVENTION 

Dynamic Random Access Memory devices (DRAMs) are among the 
15 highest volume and most complex integrated ckcuits manufactured today. 
Except for their high volume production, the state of the art manufacturing 
requirements of these devices would cause them to be exorbitantly priced. 
Yet, due to efficiencies associated with high volume production, the price 
per bit of these memory devices is continually declining. The low cost of 
20 memory has fueled the growth and development of the personal computer. 
As personal computers have become more advanced, they in turn have 
required faster and more dense memory devices, but with the same low cost 
of the standard DRAM. Fast page mode DRAMs are the most popular 
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standard DRAM today. In fast page mode operation, a row address strobe 
(/RAS) is used to latch a row address portion of a multiplexed DRAM 
address. Multiple occurrences of the column address strobe (/CAS) are then 
used to latch multiple column addresses to access data within the selected 
row. On the falling edge of /CAS an address is latched, and the DRAM 
outputs are enabled. When /CAS transitions high the DRAM outputs are 
placed in a high impedance state (tri-state). With advances in the 
production of integrated circuits, the internal circuitry of the DRAM 
operates faster than ever. This high speed circuitry has allowed for faster 
page mode cycle times. A problem exists in the reading of a DRAM when 
the device is operated with minimum fast page mode cycle times. /CAS 
may be low for as little as 15 nanoseconds, and the data access time from 
/CAS to valid output data (tCAC) may be up to 15 nanoseconds; therefore, 
in a worst case scenario there is no time to latch the output data external to 
the memory device. For devices that operate faster than the specifications 
require, the data may still only be valid for a few nanoseconds. On a 
heavily loaded microprocessor memory bus, trying to latch an asynchronous 
signal that is valid for only. a few nanoseconds is very difficult Even 
providing a new address every 35 nanoseconds requires large address 
drivers which create significant amounts of electrical noise within the 
system. To increase the data throughput of a memory system, it has been 
common practice to place multiple devices on a common bus. For example, 
two fast page mode DRAMs may be connected to common address and data 
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buses. One DRAM stores data for odd addresses, and the other for even 
addresses. The /CAS signal for the odd addresses is turned off (high) when 
the /CAS signal for the even addresses is turned on (low). This interleaved 
memory system provides data access at twice the rate of either device alone. 

5 If the first /CAS is low for 20 nanoseconds and then high for 20 
nanoseconds while the second /CAS goes low, data can be accessed every 
20 nanoseconds or 50 megahertz. If the access time from /CAS to data 
valid is fifteen nanoseconds, the data will be valid for only five 
nanoseconds at the end of each 20 nanosecond period when both devices are 

10 operating in fast page mode. As cycle times are shortened, the data valid 
period goes to zero. 

There is a demand for faster, higher density, random access memory 
integrated circuits which provide a strategy for integration into today's 

15 personal computer systems. In an effort to meet this demand, numerous 
alternatives to the standard DRAM architecture have been proposed. One 
method of providing a longer period of time when data is valid at the 
outputs of a DRAM without, increasing the fast page mode cycle time is 
called Extended Data Out (EDO) mode. In an EDO DRAM the data Imes 

20 are not tri-stated between read cycles in a fast page mode operation. 
Instead, data is held valid after /CAS goes high until sometime after the next 
/CAS low pulse occurs, or until /RAS or the output enable (/OE) goes high. 
Determining when valid data will arrive at the outputs of a fast page mode 
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or EDO DRAM can be a complex function of when the column address 
inputs are valid, when /CAS falls, the state of /OE and when /CAS rose in 
the previous cycle. The period during which data is valid with respect to the 
control line signals (especially /CAS) is determined by the specific 
5 implementation of the EDO mode, as adopted by the various DRAM 
manufacturers. 

Methods to shorten memory access cycles tend to require additional 
circuitry, additional control puis and nonstandard device pinouts. The 

10 proposed industry standard synchronous DRAM (SDRAM)for example has 
an additional pin for receiving a system clock signal. Since the system 
clock is connected to each device in a memory system, it is highly loaded, 
and it is always toggling circuitry in every device. SDRAMs also have a 
clock enable pin, a chip select pin and a data mask pin. Other signals which 

15 appear to be similar in name to those found on standard DRAMs have 
dramatically different functionality on a SDRAM. The addition of several 
control pins has required a deviation in device pinout jfrom standard 
DRAMs which further complicates design efforts to utilize these new 
devices. Significant amounts of additional circuitry are requned in the 

20 SDRAM devices which in turn result in higher device manufacturing costs. 

In order for existing computer systems to use an improved device 
having a nonstandard pinout, those systems must be extensively modified. 
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Additionally, existing computer system memory architectures are designed 
such that control and address signals may not be able to switch at the 
frequencies required to operate the new memory device at high speed due to 
large capacitive loads on the signal lines. The Single In-Line Memory 

5 Module (SIMM) provides an example of what has become an industry 
standard form of packaging memory in a computer system. On a SIMM, all 
address lines connect to all DRAMs. Further, the row address strobe 
(/RAS) and the write enable (AVE) are often coimected to each DRAM on 
the SIMM. These lines inherently have high capacitive loads as a result of 

10 the number of device inputs driven by them. SIMM devices also typically 
ground the output enable (/OE) pin making /OE a less attractive candidate 
for providing extended functionality to the memory devices. 

Tliere is a great degree of resistance to any proposed deviations from 
15 the standard SIMM design due to the vast number of computers which use 
SIMMs. Industry's resistance to radical deviations from the standard, and 
the inability of current systems to accommodate the new memory devices 
will delay their widespread acceptance. Therefore only limited quantities of 
devices with radically different architectures will be manufactured initially. 
20 This limited manufacture prevents the reduction in cost which typically can 
be accomplished through the manufacturing improvements and efficiencies 
associated with a high volume product. 
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<;t TMM at? V OF THE TNVF.NTTON 

An integrated circuit memory device with a standard DRAM pinout is 
designed for high speed data access and for compatibility with existing 

5 memory systems. A high speed burst mode of operation is provided where 
multiple sequential accesses occur following a single column address, and 
read data is output relative to the /CAS control signal. In the burst mode of 
operation the address is incremented internal to the device eliminating the 
need for external address lines to switch at high frequencies. Read/Write 

10 commands are issued once per burst access eliminating the need to toggle 
the ReadAVrite control line at high speeds. Only one control line per 
memory chip (/CAS) must toggle at the operating frequency in order to 
clock the internal address counter and the data input/output latches. The 
load on each /CAS is typically less than the load on the other control signals 

15 (/RAS, /WE and /OE) since each /CAS typically controls only a byte width 
of the data bus. Internal circuitry of the memory device is largely 
compatible with existing Extended Data Out (EDO) DRAMs. This 
similarity allows the two part types to be manufactured on one die with a 
limited amount of additional circuitry. The ability to switch between a 

20 standard non-burst mode and a high speed burst mode allows the device to 
be used to replace standard devices, and eliminates the need to switch to 
more complex high speed memory devices. Internal address generation 
provides for faster data access times than is possible with either fast page 
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mode or EDO DRAMs. The high speed operation of this Burst EDO device 
eliminates the need to interleave memory devices in order to attain a high 
data throughput. In contrast to the 50 megahertz interleaved memory 
system described above, the output data from this device will be valid for 
5 approximately 15 nanoseconds significantly easing the design of circuitry 
required to latch the data from the memory. The device is compatible with 
existing memory module pinouts. Memory modules include, but are not 
limited to Single In-Line Memory Modules (SIMMs), Multi-Chip Modules 
(MCMs) and Dual In-Line Memory Modules (DIMMs), This combination 
10 of features allows for significant system performance improvements with a 
minimum of design alterations • 



A system is adapted to receive Fast Page, EDO or Burst EDO mode 
memory devices. The devices may be installed by the system manufacture 

15 in a permanent maimer such as soldered on to a system board, or 
interchangeably through the use of memory modules. Memory modules can 
be easily upgraded by tiie user or a technician to allow for increased density, 
increased performance, or lov/er power consumption. In the event that one 
memory type is unavailable, or is being sold at a higher price than other 

20 memory types, the system manufacturer can install the memory that best 
meets his price/performance and availability needs. If a system is sold with 
Fast Page Mode memory, the end user of the system can at a later date 
upgrade the system to EDO or Burst EDO memory to achieve a 
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performance increase. If the system has EDO memory, the user may 
upgrade to Burst EDO for a significant increase in performance. 
Alternately, if the user desires an increase in memory capacity, but does not 
want to pay a higher price for high performance memory, he can upgrade in 
5 memory density with a lower performance memory type. 

The system allows for multiple types of memory being present in the 
system concurrently. A first bank of memory for example may be Burst 
EDO memory, while a second bank is EDO memory. The memory 
10 controller is programmed to access the first bank in a Burst EDO format at a 
first access rate, and the second bank in an EDO format at a second access 
rate. Most frequently accessed data should be stored in the bank with the 
fastest access capability. This allows the user to have high memory 
capacity, and high speed access to at least a portion of the memory. 

15 

The system on power up or reset can determine the type of memory 
present in each memory bank, and adjust memory access signal timing 
parameters accordingly. The user has a greater ability to control the 
systems price/performance characteristics. 

20 
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RTRTPP DRSCRTPTTON OF THK DRAWINGS 

The features of the invention as well as objects and advantages will 
be best understood by reference to the appended claims, detailed description 
of particular embodiments and accompanying drawings where: 

FIG. 1 is an electrical schematic diagram of a Burst EDO memory 
device; 

FIG. 2 is a table showing linear versus interleaved addressing 
formats; 

FIG. 3 is one suggested pinout of the memory device of FIG. 1; 

FIG. 4 is a timing diagram for a method of accessing the device of 
FIG. I; 

FIG. 5 is a further timing diagram for accessing the device of FIG. 1; 

FIG. 6 is an electrical schematic diagram of a Single In-Line Memor>' 
Module; 

Micron Technology, Inc. -9- 95-0128 
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FIG. 7 is a front view of a Single In-Line Memory Module; 

FIG. 8 is a table of the pin numbers and signal names of the Single 
In-Line Memory Module of FIG. 7; 

5 

FIG. 9 is a schematic diagram of a system designed in accordance 
with the present invention; and 

FIG. 10 is a timing diagram of one method of determining which type 
10 of memory is present in a system. 

FIG. 1 1 is a timing diagram of another method of determining which 
type of memory is present in a system. 

15 

HFTAH FD DHSCRTP TTON OF THE PRKFF.RRRD KMBODTMENTS 

FIG. 1 is a schematic representation of a sixteen megabit device 
designed in accordance with the present invention. The device is organized 
20 as a 2Meg x 8 burst EDO DRAM having an eight bit data input/output path 
10 providing data storage for 2,097,152 bytes of information in the memory 
array 12. The device of FIG. 1 has an industry standard pinout for eight bit 
wide EDO DRAMs. An active-low row address strobe (/RAS) signal 14 is 
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used to latch a first portion of a multiplexed memory address, from address 
inputs AO through AlO 16, in latch 18, The latched row address 20 is 
decoded in row decoder 22. The decoded row address is used to select a 
row of the memory array 12. A column address strobe (/CAS) signal 24 is 
5 used to latch a second portion of a memory address from address inputs 16 
into column address counter 26. The latched column address 28 is decoded 
in column address decoder 30. The decoded column address is used to 
select a column of the memory array 12. 

10 In a burst read cycle, data within the memory array located at the row 

and column address selected by the row and column address decoders is 
read out of the memory array and sent along data path 32 to output latches 
34. Data 10 driven from the burst EDO DRAM may be latched external to 
the device in synchronization with /CAS after a predetermined number of 

15 /CAS cycle delays (latency). For a two cycle latency design, the first /CAS 
falling edge is used to latch the initial address for the burst access. The first 
burst data from the memory is driven from the memory after the second 
/CAS falling edge, and remains valid through the third /CAS falling edge. 
Once the memory device begins to output data in a burst read cycle, the 

20 output drivers 34 will continue to drive the data lines without tri-stating the 
data outputs during /CAS high intervals dependent on the state of the output 
enable and write enable (/OE and /WE) control lines, thus allowing 
additional time for the system to latch the output data. Once a row and a 
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column address are selected, additional transitions of the /CAS signal are 
used to advance the column address within the column address counter in a 
predetermined sequence. The time at which data will be valid at the outputs 
of the burst EDO DRAM is dependent only on the timing of the /CAS signal 
5 provided that /OE is maintained low, and /WE remains high. The output 
data signal levels may be driven in accordance with standard CMOS, TTL, 
LVTTL, GTL, or HSTL output level specifications or others. 

The address may be advanced linearly, or in an interleaved fashion 
10 for maximum compatibility with the overall system requirements. FIG, 2 is 
a table which shows linear and interleaved addressing sequences for burst 
lengths of 2,4 and 8 cycles. The "V" for starting addresses Al and A2 in 
the table represent address values that remain unaltered through the burst 
sequence. The column address may be advanced with each /CAS transition, 
15 each pulse, or multiple of /CAS pulses in the event that more than one data 
word is read from the array with each column address. When the address is 
advanced with each transition of the /CAS signal, data is also driven from 
the part after each transition following the device latency which is then 
referenced to each edge of the /CAS signal. This allows for a burst access 
20 cycle where the highest switching control line (/CAS) toggles only once 
(high to low or low to high) for each memory cycle. This is in contrast to 
standard DRAMs which require /CAS to go low and then high for each 
cycle, and synchronous DRAMs which require a frill clock cycle (high and 
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low transitions) for each memory cycle. For maximum compatibility with 
existing EDO DRAM devices, the invention will be further described in 
reference to a device designed to latch and advance a column address on 
falling edges of the /CAS signal. 

5 

It may be desurable to latch and increment the column address after 
the first /CAS falling edge in order to apply both the latched and 
incremented addresses to the array at the earliest opportunity in an access 
cycle. For example, a device may be designed to access two data words per 

10 cycle (prefetch architecture). The memory array for a prefetch architecture 
device may be split into odd and even array halves. The column address 
least significant bit is then used to select between odd and even halves while 
the other colunm address bits select a column within each of the array 
halves. In an interleaved access mode with column address 1, data from 

1 5 columns 0 and 1 would be read and the data from column 1 would be output 
followed by the data from column 0 in accordance with standard interleaved 
addressing as described in SDRAM specifications. In a linear access mode 
column address 1 would be applied to the odd array half, and incremented 
to address 2 for accessing the even array half to fiilfill the two word access. 

20 One method of implementing this type of device architecture is to provide a 
column address incrementing circuit between the column address counter 
and the even array half The incrementing circuit would increment the 
column address only if the initial column address in a burst access cycle is 
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odd, and the address mode is linear. Otherwise the incrementing circuit 
would pass the column address unaltered. For a design using a prefetch of 
two data accesses per cycle, the column address would be advanced once 
for every two active edges of the /CAS signal. Prefetch architectures where 
5 more than two data words are accessed are also possible. 

Other memory architectures applicable to the current invention 
include a pipelined architecture where memory accesses are performed 
sequentially, but each access may require more than a single cycle to 
10 complete. In a pipelined architecture the overall throughput of the memory 
will approach one access per cycle, but the data out of the memory may be 
offset by a number of cycles due to the pipeline length and/or the desired 
latency from /CAS. 

15 In the burst access memory device, each new column address from 

the column address counter is decoded and is used to access additional data 
within the memory array without the requirement of additional column 
addresses being specified on the address inputs 16. This burst sequence of 
data will continue for each /CAS falling edge until a predetermined number 

20 of data accesses equal to the burst length has occurred. A /CAS falling edge 
received after the last burst address has been generated will latch another 
column address from the address inputs 16 and a new burst sequence will 
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begin. Read data is latched and output with each falling edge of /CAS after 
the first /CAS latency. 

For a burst write cycle, data 10 is latched in input data latches 34. 
5 Data targeted at the first address specified by the row and column addresses 
is latched with the /CAS signal when the first column address is latched 
(write cycle data latency is zero). Other write cycle data latency values are 
possible; however, for today's memory systems, zero is preferred. 
Additional input data words for storage at incremented column address 

10 locations are latched by /CAS on successive /CAS pulses. Input data from 
the input latches 34 is passed along data path 32 to the memory array where 
it is stored at the location selected by the row and column address decoders. 
As in the burst read cycle previously described, a predetermined number of 
burst access writes will occur without the requirement of additional column 

15 addresses being provided on the address lines 16. After the predetermined 
number of burst writes has occurred, a subsequent /CAS pulse will latch a 
new beginning column address, and another burst read or write access will 
begin. 

20 The memory device of FIG, 1 may include the option of switching 

between burst EDO and standard EDO modes of operation. In this case, the 
write enable signal /WE 36 may be used at the row address latch time (/RAS 
falling, /CAS high) to determine whether memory accesses for that row will 
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be burst or page mode cycles. If /WE is low when /RAS falls, burst access 
cycles are selected. If /WE is high at /RAS falling, standard extended data 
out (EDO) page mode cycles are selected. Both the burst and EDO page 
mode cycles allow for increased memory device operating frequencies by 

5 not requiring the data output drivers 34 to place the data lines 10 in a high 
impedance state between data read cycles while /RAS is low. DRAM 
control circuitry 38, in addition to performing standard DRAM control 
functions, controls the I/O circuitry 34 and the column address counter/latch 
26 in accordance with the mode selected by /WE when /RAS falls. In a 

10 burst mode only DRAM, or in a device designed with an alternate method 
of switching between burst and non-burst access cycles, the state of /WE 
when /RAS falls may be used to switch between other possible modes of 
operation such as interleaved versus linear addressing modes. 

15 The write enable signal is used m burst access cycles to select read or 

write burst accesses when the initial column address for a burst cycle is 
latched by /CAS. /WE low at the column address latch time selects a burst 
write access. /WE high at the column address latch time selects a burst read 
access. The level of the /WE signal must remmn high for read and low for 

20 write burst accesses throughout the burst access. A low to high transition 
within a burst write access will terminate the burst access, preventing 
fiirther writes from occurring. A high to low transition on /WE within a 
burst read access will likewise terminate the burst read access and will place 
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the data output 10 in a high impedance state. Transitions of the AVE signal 
may be locked out during critical timing periods within an access cycle in 
order to reduce the possibility of triggering a false write cycle. After the 
critical timing period the state of fWE will determine whether a burst access 

5 continues, is initiated, or is terminated. Termination of a burst access 
resets the burst length counter and places the DRAM in a state to receive 
another burst access command. Both /RAS and /CAS going high during a 
burst access will also terminate the burst access cycle placing the data 
drivers in a high impedance output state, and resetting the burst length 

10 counter. Read data may remain valid at the device outputs if /RAS alone 
goes high while /CAS is active for compatibility with hidden refresh cycles, 
otherwise /RAS high alone may be used to terminate a burst access. A 
minimum write enable pulse width is only required when it is desired to 
terminate a burst read and then begin another burst read, or terminate a burst 

15 write prior to performing another burst write with a minimum delay 
between burst accesses. In the case of burst reads, /WE will transition from 
high to low to terminate a first burst read, and then /WE will transition back 
high prior to the next falling edge of /CAS in order to specify a new burst 
read cycle. For burst writes, /WE would transition high to terminate a 

20 current burst write access, then back low prior to the next falling edge of 
/CAS to initiate another burst write access. 
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A basic implementation of the device of FIG. 1 may include a fixed 
burst length of 4, a fixed /CAS latency of 2 and a fixed interleaved sequence 
of burst addresses. This basic implementation requires very little additional 
circuitry to the standard EDO page mode DRAM, and may be mass 

5 produced to provide the fimctions of both the standard EDO page mode and 
burst EDO DRAMs. This device also allows for the output enable pin (/OE) 
to be grounded for compatibility with many SIMM module designs. When 
not disabled (tied to ground), /OE is an asynchronous control which will 
prevent data fi-om being driven fi-om the part in a read cycle if it is inactive 

10 (high) prior to /CAS falling and remains inactive beyond /CAS rising. If 
these setup and hold conditions are not met, then the read data may be 
driven for a portion of the read cycle. It is possible to synchronize the /OE 
signal with /CAS, however this would typically increase the /CAS to data 
valid delay time and doesn't allow for the read data to be disabled prior to 

1 5 /RAS high without an additional /CAS low pulse which would otherwise be 
unnecessary. In a preferred embodiment, if /OE transitions high at any time 
during a read cycle the outputs will remain in a high impedance state until 
the next falling edge of /CAS despite further transitions of the /OE signal. 

20 Programmability of the burst lengtii, /CAS latency and address 

sequences may be accomplished through the use of a mode register 40 
which latches the state of one or more of the address input signals 16 or data 
signals 10 upon receipt of a write-/CAS-before-/RAS (WCBR) 
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programming cycle. In such a device, outputs 44 from the mode register 
control the required circuits on the DRAM. Burst length options of 2, 4, 8 
and full page as well as /CAS latencies of 1, 2 and 3 may be provided. 
Other burst length and latency options may be provided as the operating 

5 speeds of the device increase, and computer architectures evolve. The 
device of FIG. 1 includes programmability of the address sequence by 
latching the state of the least significant address bit during a WCBR cycle. 
The burst length and /CAS latency for this particular embodiment are fixed. 
Other possible alterations in the feature sets of this DRAM include having a 

10 fixed burst mode only, selecting between standard fast page mode (non- 
EDO) and burst mode, and using the output enable pin (/OE) 42 in 
combination with /RAS to select between modes of operation. Also, a 
WCBR refresh cycle could be used to select the mode of operation rather 
than a control signal in combination with /RAS. A more complex memory 

15 device may provide additional modes of operation such as switching 
between fast page mode, EDO page mode, static column mode and burst 
operation through the use of various combinations of /WE and /OE at /RAS 
falling time. One mode from a similar set of modes may be selected 
through the use of a WCBR cycle using multiple address or data lines to 

20 encode the desired mode. Alternately, a device with multiple modes of 
operation may have wire bond locations, or programmable fiises which may 
be used to program the mode of operation of the device. 
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A preferred embodiment of a sixteen bit wdde burst EDO mode DRAM 
designed in accordance with the teachings of this invention has two column 
address strobe input pins /CASH and /CASL. For read cycles only one /CAS 
signal needs to toggle. The second /CAS may remain high or toggle with the 

5 other /CAS. During burst read cycles, all sixteen data bits will be driven out 
of part during a read cycle even if one /CAS remains uiactive. In a typical 
system application, a microprocessor reads all data bits on a data bus in each 
read cycle, but may only write certain bytes of data in a write cycle. 
Allowing one of the /CAS control signals to remain static during read cycles 

10 helps to reduce overall power consumption and noise within the system. For 
burst write access cycles, each of the /CAS signals (CASH and /CASL) acts 
as a write enable for an eight bit width of the data. The two /CAS's are 
combined in an AND fimction to provide a single internal /CAS which will 
go low when the first external /CAS falls, and returns high after the last 

1 5 external /CAS goes high. All sixteen data inputs are latched when the first of 
the /CAS signals transitions low. If only one /CAS signal transitions low, 
then the eight bits of data associated with the /CAS that remained high are not 
stored in the memory. 

20 

The present invention has been described with reference to several 
preferred embodiments. Just as fast page mode DRAMs and EDO DRAMs 
are available in numerous configurations including xl, x4, x8 and xl6 data 
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widths, and 1 Megabit, 4Megabit, 16Megabit and 64Megabit densities; the 
memory device of the present invention may take the form of many 
different memory organizations. It is believed that one who is skilled in the 
art of integrated circuit memory design can, with the aide of this 
5 specification design a variety of memory devices which do not depart from 
the spirit of this invention. It is therefore believed that detailed descriptions 
of the various memory device organizations applicable to this invention are 
not necessary. 

10 FIG. 3 shows a preferred pinout for the device of FIG. 1 . It should be 

noted that the pinout for this new burst EDO memory device is identical to 
the pinout for a standard EDO DRAM. The common pinout allows this new 
device to be used in existing memory designs with minimum design 
changes. The common pinout also allows for ease of new designs by those 

15 of skill in the art who are familiar with the standard EDO DRAM pinout. 
Variations of the described invention which maintain the standard EDO 
DRAM pinout include driving the /CAS pin with a system clock signal to 
synchronize data access of the memory device with the system clock. For 
this embodiment, it may be desirable to use the first /CAS active edge after 

20 /RAS falls to latch the row address, a later edge may be used to latch the 
first column address of a burst access cycle. After row and column 
addresses are latched within the device, the address may be incremented 
internally to provide burst access cycles in synchronization with the system 
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clock. Other pin function alternatives include driving the burst address 
incrementing signal on the /OE pin since the part does not require a data 
output disable function on this pin. Other alternate uses of the /OE pin also 
allow the device to maintain the standard EDO pinout, but provide 
5 increased functionality such as burst mode access. The /OE pin may be 
used to signal the presence of a valid column starting address, or to 
terminate a burst access. Each of these embodiments provides for a high 
speed burst access memory device which may be used in current memory 
systems with a minimum amount of redesign. 

10 

FIG. 4 is a timing diagram for performing a burst read followed by a 
burst write of the device of FIG. 1. In FIG. 4, a row address is latched by 
the /RAS signal. /WE is low when /RAS falls for an embodiment of the 
design where the state of the /WE pin is used to specify a burst access cycle 

15 at /RAS time. Next, /CAS is driven low with /WE high to initiate a burst 
read access, and the column address is latched. The data out signals (DQ's) 
are not driven in the first /CAS cycle. On the second falling edge of the 
/CAS signal, the internal address generation circuitry advances the column 
address and begins another access of the array, and the first data out is 

20 driven from the device after a /CAS to data access time (tCAC). Additional 
burst access cycles continue, for a device with a specified burst lengtili of 
four, until the fifth falling edge of /CAS which latches a new column 
address for a new burst read access. /WE falling in the fifth /CAS cycle 
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terminates the burst access, and initializes the device for additional burst 
accesses. The sixth falling edge of /CAS with /WE low is used to latch a 
new burst address, latch input data and begin a burst write access of the 
device. Additional data values are latched on successive /CAS falling edges 
5 until /RAS rises to terminate the burst access. 

FIG. 5 is a timing diagram depicting burst write access cycles 
followed by burst read cycles. As in FIG. 4, the /RAS signal is used to latch 
the row address. The first /CAS falling edge in combmation with /WE low 

1 0 begins a burst write access with the first data being latched. Additional data 
values are latched with successive /CAS falling edges, and the memory 
address is advanced internal to the device in either an interleaved or 
sequential manner. On the fifth /CAS falling edge a new column address 
and associated write data are latched. The burst write access cycles 

15 continue until the /WE signal goes high in the sixth /CAS cycle. The 
transition of the /WE signal terminates the burst write access. The seventh 
/CAS low transition latches a new column address and begins a burst read 
access (/WE is high). The burst read continues until /RAS rises terminating 
the burst cycles. 

20 

It should be noted fi:om FIG.'s 3 and 4, that for burst read cycles the 
data remains valid on the device outputs as long as the /OE pin is low, 
except for brief periods of data transition. Also, since the /WE pin is low 
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prior to or when /CAS falls, the data input/output lines are not driven from 
the part during write cycles, and the /OE pin is a "don't care". Only the 
/CAS signal and the data signals toggle at relatively high frequency, and no 
control signals other than /CAS are required to be in an active or inactive 

5 state for one /CAS cycle time or less. This is in contrast to SDRAMs which 
often require row address strobes, column address strobes, data mask, and 
read/write control signals to be valid for one clock cycle or less for various 
device fimctions. Typical DRAMs also allow for the column address to 
propagate through to the array to begin a data access prior to /CAS falling. 

10 This is done to provide fast data access from /CAS falling if the address has 
been valid for a sufficient period of time prior to /CAS falling for the data to 
have been accessed from the array. In these designs an address transition 
detection circuit is used to restart the memory access if the column address 
changes prior to /CAS falling. This method actually requires additional 

15 time for performing a memory access since it must allow for a period of 
time at the beginning of each memory cycle after the last address transition 
to prepare for a new column address. Changes in the column address just 
prior to /CAS falling may increase the access time by approximately five 
nanoseconds. An embodiment of the present invention will not allow the 

20 column address to propagate through to the array until after /CAS has fallen. 
This eliminates the need for address transition detection circuitry, and 
allows for a fixed array access relative to /CAS. 
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FIG. 6 is a schematic representation of a single in-line memory 
module (SIMM) designed in accordance with the present mvention. The 
SIMM has a standard SIMM module pinout for physical compatibility with 
existing systems and sockets. Functional compatibility with EDO page 
5 mode SIMMs is maintained when each of the 2Meg x 8 memory devices 10, 
12, 14 and 16 are operated in an EDO page mode. Each of the /CAS signals 
18, 20, 22 and 24 control one byte width of the 32 bit data bus 26, 28, 30 
and 32. A /RAS 34 signal is used to latch a row address in each of the 
memory devices, and is used in combination with AVE 36 to select between 

10 page mode and burst mode access cycles. Address signals 38 provide a 
multiplexed row and column address to each memory device on the SIMM, 
In burst mode, only active /CAS control lines are required to toggle at the 
operating frequency of the device, or at half the frequency if each edge of 
the /CAS signal is used as described above. The data lines are required to 

15 be switchable at half of the frequency of the /CAS lines or at the same 
frequency, and the other control and address signals switch at lower 
frequencies than /CAS and the data lines. As shown in FIG. 6, each /CAS 
signal and each data line is connected to a single memory device allowing 
for higher frequency switching than the other control and address signals. 

20 Each of the memory devices 10, 12, 14 and 16 is designed in accordance 
with the present invention allowing for a burst mode of operation providing 
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internal address generation for sequential or interleaved data access from 
multiple memory address locations with timing relative to the /CAS control 
lines after a first row and column address are latched. 

5 

FIG. 7 shows a front view of another SIMM designed in accordance 
with the present invention. Each device on the SIMM is a 4Megabit DRAM 
organized as lMegx4. In this configuration, a single /CAS controls two 
memory devices to provide access to a byte width of the data bus. The eight 
10 devices shown form a 4Megabyte SIMM in a 32 bit width. For an 
SMegabyte SIMM in a 32 bit width, there are eight additional devices on 
the back side (not shown). 

FIG. 8 shows a preferred pinout for a memory module designed in 
15 accordance with the device of FIG. 7. This pinout is compatible with 
pinouts for Fast Page Mode SIMMs and EDO SIMMs. A presence detect 
pin is provided for indication of EDO operation on pui 66, and m 
accordance with standard EDO part types, an /OE input is provided on pin 
46. 

20 

Alternate embodiments of the SIMM modules of FIG.'s 5,6 and 7 
include the use of two /RAS signals with each controlling a sixteen bit 
width of the data bus in accordance with standard SIMM module pinouts. 



Micron Technology, Inc. 



-26- 



95-0128 



Inventor(s): Williams 

Four more 2M x 8 EDO Burst Mode DRAMs may be added to the device of 
FIG. 6 to provide for a 4M x 32 bit SIMM. Sixteen bit wide DRAMs may 
also be used, these will typically have two /CAS signals each of which 
controls an eight bit data width. The incorporation of parity bits, or error 

5 detection and correction circuitry provide other possible SIMM module 
configurations. Methods of performing error detection and/or correction are 
well known to those of skill m the art, and detailed descriptions of such 
circuits are not provided in this application. Additional SIMM designs 
using the novel memory device of the present invention may be designed by 

10 one of skill in the art with the aid of this specification. The invention has 
been described with reference to SIMM designs, but is not limited to 
SIMMs. The invention is equally applicable to other types of memory 
modules including Dual In-Line Memory Modules (DIMMs) and Multi- 
Chip Modules (MCMs). 

15 

FIG. 9 is a schematic representation of a data processing apparatus 
designed in accordance with the present invention. For the purposes of this 
specification a microprocessor may be, but is not limited to, a 
microprocessor, a microcontroller, a digital signal processor, or an arithmetic 
20 processor. In FIG. 9, microprocessor 1 12 is connected via address lines 1 14 
and control lines 1 16 to a memory control ckcuit 118. The memory control 
circuit provides address and control signals on lines 122 and 120 respectively 
to a memory 124. Additional buffer circuitry between the memory control 
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circuit and the memory, for the address and/or control signals, may be 
provided. The memory sends and receives data over data bus 126. Optional 
data bus buffer 130 between memory data bus 126 and microprocessor data 
bus 128 allows for amplification of the data signals, and/or synchronization 
5 with the microprocessor and memory control signals. The buffer may be, but 
is not limited to, a buffer, transceiver, latch, register, or registered 
transceiver. A fast static random access memory (SRAM) cache cncuit 132 
is also optional and provides higher speed access to data stored in the cache 
from the memory curcuit or the microprocessor. Memory control circuit 118 
10 may be incorporated vMhm the microprocessor. The memory control circuit 
provides the required address strobe signals, address signals and read/write 
control signals required to access a variety of memory types. The capability 
of the processor to access the memory in a burst mode allows for the design 
of a computer with relatively high memory bandwidth without the 
1 5 requirement of a fast SRAM cache. SRAMs which are fast enough to provide 
memory access without wait states can significantly add to the cost of a 
computer. The ability of the system to accept Burst EDO memory in 
accordance with the present invention also allows for medium to lugh 
performance computers to be manufactured at a cost which is significantly 
20 less than those manufactured today. Use of burst access memory in 
cooperation with a fast SRAM cache allows for an even higher performance 
computer design by providing fast burst access of main memory m the event 
of a cache miss. 
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In operation, when Burst EDO memory is present the microprocessor 
reads data by supplying address and control signals to the memory through 
the memory control circuit In response to an initial address, a read command 

5 and an access cycle strobe, the memory begins to access a first data word at 
the initial address. A second access cycle strobe advances the address within 
the memory in a second access period of the burst access, and initiates a read 
access of data from a second address. For a latency of two, the first data is 
driven from the memory after the second access cycle strobe signal occurs. 

10 Typically the first data is latched in the microprocessor in response to a third 
access cycle strobe which occurs at the beginnmg of a third access cycle 
period of the burst access. The third access cycle strobe also causes the 
second data value to be driven from the memory. The third access cycle 
strobe also causes a third address to be generated within the memory, and a 

15 third data access begins. Data is latched in the microprocessor in response to 
fourth, fifth and sixth access cycle strobes. In this manner four data values 
are received in the microprocessor in response to a single address and a 
plurality of access cycle strobes. The microprocessor may provide a second 
address to the memory with the fifth access cycle strobe signal if the memory 

20 is designed to perform four word burst sequences and additional data values 
are required from the memory. In this case, a second four word burst 
sequence is begun while the microprocessor is receiving data from the first 
four word burst. The data buffer 130 may be used to synchronize data from 
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the memory received in response to the access cycle strobe signal, with a 
system clock which is connected to the microprocessor. For write cycles, 
there is typically no latency. Data for write cycles is provided with each 
access cycle strobe signal in a burst write sequence. 

5 

In a preferred embodiment of the present invention, the system of Fig. 
9 will operate with one of two or more different types of memory. For 
example, the system may operate with Burst EDO, Fast Page Mode, or EDO 
memory devices. The system for example, may be adapted to receive 
10 memory modules having Fast Page Mode, EDO or Burst EDO memory 
devices where the modules have identical or nearly identical pinouts. 

In this system, a method of detecting the type of memory present 
utilizes some or all of the following steps: Write a first data pattern into the 

15 memory at address n; toggle /CAS low with a read command at address n; 
sample the data output of the memory; toggle /CAS high; sample the data 
ou^ut of the memory. If the iSrst data sample matches the data written into 
the memory, then the memory is either Fast Page Mode or EDO provided that 
the address to data valid and /CAS to data valid times have been met for both 

20 types of memory. If the second sample matches the data written into the 
memory, then the memory is EDO since the data bus will not be driven while 
/CAS is high for Fast Page Mode, and the latency will not have been met for 
Burst EDO memory. If the first pattern matches, but the second does not. 
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then the memory is Fast Page Mode. If valid data is not detected for /CAS 
low or /CAS high, then the memory is Burst EDO. /CAS may be toggled low 
to perform additional read cycles with or without altering the column address 
to detect valid data to verify the presence of Burst EDO memory and to 

5 determine the latency. A system which is designed to accept only one of Fast 
Page Mode and EDO or Burst EDO memory would only need to sample data 
at the appropriate time (/CAS low for Fast Page Mode, and /CAS high for 
EDO) during the first read cycle to determine which type of memory is 
present. Systems designed to accept only EDO or Burst EDO memory for 

10 example may not have the capability of sampling data while /CAS is low 
when Fast Page Mode data would be valid. Figure 10 shows a timing 
diagram where a known data pattern Dn is written into memory in a format 
which is compatible with each of the possible memory types that may be 
present in the system. At time tl, the memory output is sampled while /CAS 

15 is low as described above. If valid data is not read, then the memory is Burst 
EDO. At time t2, the memory output is sampled while /CAS is high. If valid 
data was read at time tl, then the presence or absence of valid data at time t2 
will reveal whether the data is Fast Page Mode or EDO. For Burst EDO 
memory with a latency of two, data sampled at time t3 or t4 will match the 

20 data written into the memory. At time t4 in particular, each of the three 
memory types would provide a different result on the memory data outputs 
allowing for memory type determination. 
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A method for differentiating between Burst EDO and Fast Page Mode 
or EDO alternately utilizes the following steps: Write a first data pattern into 
the memory at address n; write a second data pattern into the memory at 
address n+1; write a third data pattern into the memory at address n+2; write 

5 a fourth data pattern into the memory at address n+3; cycle /CAS five times 
to read data in a Burst EDO burst read format while maintaining address n on 
the external address lines. The data may be written in single discrete cycles, 
page mode cycles, or in Burst EDO format. If the data received matches the 
data written but is offset by at least one cycle (latency), then the memory is 

1 0 Burst EDO. If the memory is not Burst EDO, then the data read will be either 
all equal to the data pattern written at address n if single cycles or page mode 
writes were performed and the memory is EDO memory, or the data will be 
equal to the data pattern written at address n+3 if Burst EDO writes were 
performed and the memory is EDO memory, or the data will be dependent 

15 upon the characteristics of the data bus and the memory is Fast Page Mode 
memory. If the data is sampled while /CAS is high and the memory is Fast 
Page Mode, then the data bus may float high, low, or be unknown when the 
data is sampled. If the data is sampled while /CAS is low, then Fast Page 
Mode memory will provide the same data as EDO memory. 

20 
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In the event that the data output of the memory is only sampled while 
/CAS is high and valid data is not received, the memory should be accessed 
in a Fast Page Mode format to verify the presence of Fast Page Mode 
5 memory. 

Figure 1 1 is a timing diagram of another method of determining which 
type of memory is present in a system, in accordance with the teachings of 
this invention. For the purposes of providing a specific example, the data 

10 values shown correspond to a system where the data width is four bits, hi 
practice, a typical system data bus may have 8, 16, 32, 64 or some other data 
width. Likewise while the timing diagram may be viewed with reference to 
the system of figure 9, the method described is equally useful for a wide 
variety of system configurations in accordance with the teachings of the 

15 present invention which are capable of utilizuig memory devices which may 
operate in one or more of at least two (Afferent access modes. In figure 11, 
two data values are written into memory using a page mode write format 
This format will correctly store data mto Fast Page Mode, EDO, or Burst 
EDO memory devices. If the memory is Burst EDO, the second column 

20 address presented (Cn+1) will simply be ignored by the memory device or 
devices being written to since the second address will be internally generated. 
After the writing the two data values (0110 and 1001) which should be 
chosen to be easily distinguishable fi-om each other and fi-om a bus that is not 
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driven, the memory is read in a Burst EDO format The waveform labeled 
DATA FPM is a representation of the data bus for a system where Fast Page 
Mode memory is installed. The waveform labeled DATA EDO is a 
representation of the data bus for a system where EDO memory is installed, 
5 The waveform labeled DATA BEDO is a representation of the data bus for a 
system where Burst EDO memory is installed. The vertical lines tl, t2, t3, t4 
and t5 represent some possible times when data may be sampled in order to 
differentiate between the possible types of memory present in the system. At 
time t5 in particular, each memory type provides a different response to the 

10 read operation. Fast Page Mode memory will not be driving the data bus at 
time t5 since /CAS is high. When the bus is not driven, it will typically float 
or be terminated to a level that will be digitally interpreted as being either 
high, low, or a pattem of high and low values. In any case the data is not 
likely to match the pattem written. For systems utilizing a narrow data bus, 

15 or if the bus characteristics are unknown, it may be desirable to repeat the 
method with various data patterns to guarantee that the bus is not tending to 
provide signal levels that would be interpreted as a match of the data that was 
written. For wide data buses, the likelihood of an undriven bus matching a 
random or suitably varying pattem of data bits is very remote, and multiple 

20 pattems may not be deemed necessary, A possible pattem for a 32 bit data 
bus for example may be 0110 1001 1111 0001 1100 0011 0000 1110, At 
time t5, EDO memory will drive data onto the data bus from column address 
Cn since the read address is not changing from cycle to cycle. For the 
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example of figure 11 , this value is 0 1 1 0. At time t5, Burst EDO memory with 
a latency of two will provide data from column address Cn+1 since the Burst 
EDO memory will automatically increment the internal address in a burst 
read access cycle. In this manner, the memory type whether Fast Page Mode, 

5 EDO, or Burst EDO can be determined at time t5. A more comprehensive 
method will perform more than two write and three read cycles in order to 
allow for Burst EDO memory devices with latencies of other than two. For 
example, if four write cycles are followed by five read cycles, and the data is 
sampled with /CAS high after the fifth read cycle, then the data will be bus 

10 dependent for Fast Page Mode memory, still equal to the first data value for 
EDO memory, and either equal to the fourth, third or second data value for 
Burst EDO memory with latency equal to two three or four respectively. 

Another method in accordance with the present is invention is to write 
15 in single cycles to nonsequential addresses to write data into those addresses 
regardless of the memory type, then read the memory in a page mode like 
format with timing that is compatible with each of the memory types, but 
with a different address order. For example, write Dl, D2, D3 and D4 to 
addresses 00,10,11,01 respectively using single cycles (toggling both /RAS 
20 and /CAS for each cycle), then read from 00, 11, 01, 10 in a page mode like 
format. Burst EDO memory will read the data in the order of DL D4, D2, 
and D3 offset in time by the latency. Fast Page Mode and EDO memory will 
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read the data in the order Dl, D3, D4 and D2 without latency. Again, if the 
data is sampled after /CAS has been high (at /CAS falling edges for example), 
then the data from Fast Page Mode devices will most likely not be valid, 

5 

Another method of detecting a memory type in a system in accordance 
with an embodiment of this invention is to write to a number of memory 
locations using a page mode write format directed to nonsequential addresses, 
then read in a page mode format from sequential addresses. For example, the 

10 two least significant address bits may be toggled in the sequence 00, 10, 11, 
01 for the data write cycles. For page mode memory, the data will be valid 
but out of order if it is sampled after the data is valid and prior to /CAS 
transitioning high which will tri-state the data bus. For EDO memory, the 
data v^ll be valid but out of order if sampled after the data is valid and prior 

15 to the following /CAS low transition. For Burst EDO memory, the data will 
be read in order since the address least significant bits will have been 
generated within the memory in the same order for the read and the write 
cycles. The Burst EDO data will have a latency from /CAS, As few as two 
locations may be written, followed by a single read cycle to the second 

20 
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address. In this case, if valid data is sampled while /CAS is low, the memory 
must be Fast Page or EDO. If valid data is sampled after /CAS transitions 
high, the memory is EDO. If valid data is not detected, the memory is Burst 
EDO. 

5 

A simplified method of determining the type of memory present in 
accordance with the teachings of the present invention for a system utilizing 
SIMMs, makes use of the EDO presence detect pin. If the EDO presence 
detect is false, then the memory is Fast Page Mode memory. If the presence 
10 detect is true, then the memory need only be tested for EDO versus Burst 
EDO, or for memory devices with multiple modes of operation. 

An additional method in accordance with the present invention is to 
write the data in a burst mode format maintaining the column address at Cn 

15 while toggling /CAS and providing multiple data patterns. A read cycle at 
address Cn+x, where Cn+x is vdthin a range of addresses that would have 
been written to in a Burst EDO memory device, is then performed as part of a 
burst or page mode read sequence. The data pattern read from address Cn+x 
will match the pattern written to Cn+x after a latency if the memory is Burst 

20 EDO memory. Fast Page Mode and EDO memory will provide whatever 
data was present at Cn+x prior to the burst mode write. Alternately, a single 
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read cycle to address Cn, where the data is sampled near the end of the /CAS 
low period, will provide valid data out for either Fast Page Mode or EDO 
memory, but not for Burst EDO memory since the latency will not have been 
5 met. 

In each of the above methods for determining a memory type 
present in a system, the step of placing the memory in a particular mode 
should be performed if it is known that the memory itself may have multiple 

10 modes of operation. The memory may be tested after following the 
appropriate procedure for placing the memory in each of the possible desired 
modes of operation in order to determine what modes of operation the 
memory will support. Also, linear versus sequential addressing modes must 
be taken into account if the memory may have the ability to switch between 

15 these addressing modes. Any SRAM cache should be disabled prior to 
performing the methods described, or additional steps may be required to 
guarantee that data being read is not cached data only. Also, a known 
background data pattem may be written to an address range where the method 
will be used in order to avoid possible false data matches to uninitialized 

20 memory locations. 
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The present invention teaches a system having multiple memory banks 
where each memory bank may have one of several types of memory. For 
systems designed in accordance with this teaching, each bank may be 
5 individually tested as described above. The memory controller of the system 
is programmed to access each bank in accordance with the type of memory 
present. 

While the present invention has been described with reference to 
10 preferred embodiments, numerous modifications and variations of the 
invention will be apparent to one of skill in the art without departing from the 
scope of the invention. 
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What is claimed is: 



1 , A microprocessor system comprising: 
a bus for transferring information; 

a memory, coupled to said bus, comprised of a type of memory 
device which is interchangeably a Burst Extended Data Out type memory 
device or a Fast Page Mode type memory device, said memory having a 
first set of access control signal timing requirements for the Burst Extended 
Data Out type memory device and a second set of access control signal 
timing requirements for the Fast Page Mode type memory device; 

a programmable memory controller, coupled to said bus and to said 
memory, capable of providing the first set of access control signal timing 
requirements and the second set of access control signal timing 
requirements to said memory; and 



a microprocessor, coupled to said bus, said memory and said memory 
controller, responsive to information from said memory to program said 
memory controller to provide a set of access control signals to said memory 
in accordance with the type of memory device said memory is comprised of. 

2. A microprocessor system comprising: 
a bus for transferring information; 

a memory, coupled to said bus, comprised of a type of memory 
device which is interchangeably a Burst Extended Data Out type memory 
device or a Extended Data Out type memory device, smd memory havmg a 
first set of access control signal timing requirements for the Burst Extended 
Data Out type memory device and a second set of access control signal 
timing requirements for the Extended Data Out type memory device; 

a programmable memory controller, coupled to said bus and to said 
memory, capable of providing the first set of access control signal timing 



requirements and the second set of access control signal timing 
requirements to said memory; 

a nonvolatile memory device coupled to said bus; and 

a microprocessor, coupled to said bus and said memory controller, 
responsive to information from said memory and said nonvolatile memory 
device to program said memory controller to provide a set of access control 
signals to said memory in accordance with the type of memory device said 
memory is comprised of 

3 . The system of claim 2, fiirther comprising: 
a power supply; and » 

a power up detection circuit coupled to said microprocessor and to 
said power supply, said power up detection circuit responsive to a signal 
from said power supply to cause said microprocessor to access said 



nonvolatile memory device to receive information enabling said 
microprocessor to detect the type of memory device and to program the 
memory controller in accordance with the type of memory device said 
memory is comprised of. 

4. A microprocessor system comprising: 
a bus for transferring information; 

a memory, coupled to said bus, comprised of a type of memory 
device which is selected from memory devices operable in first and second 
modes, said memory having a first set of access control signals for 
operation in said first mode and a second set of access control signals for 
operation in said second mode; 

a programmable memory controller, coupled to said bus and to said 
memory, capable of providing the first set of access control signals and the 
second set of access control signals to said memory; 



a nonvolatile memory device coupled to said bus; 

a microprocessor, coupled to said bus and said memory controller, 
responsive to information from said nonvolatile memory device to program 
said memory controller to provide the first set of access control signals to 
said memory at a first time and the second set of access control signals to 
said memory at a second time. 

5. A microprocessor system comprising: 
a bus for transferring information; 
a power supply; * 



a memory, coupled to said bus, comprised of a type of memory 
device which is selected from memory devices operable in first and second 
modes, said memory having a first set of access control signals for memory 



devices operable in said first mode and a second set of access control 
signals for memory devices operable in said second mode; 

a programmable memory controller, coupled to said bus and to said 
memory, capable of providing the first set of access control signals and the 
second set of access control signals to said memory; 

a nonvolatile memory device coupled to said bus; 

a microprocessor, coupled to said bus and said memory controller, 
responsive to information from said memory and said nonvolatile memory 
device to program said memory controller to provide a set of access control 
signals to said memory in accordance with the type of memory device said 
memory is comprised of; and 

a power up detection circuit coupled to said microprocessor and to 
said power supply, said power up detection circuit responsive to a signal 
from said power supply to cause said microprocessor to access said 
nonvolatile memory device to receive information enabling said 



microprocessor to detect the type of memory device and to program the 
memory controller in accordance with the type of memory device said 
memory is comprised of 

6. A system comprising a programmable memory controller, the system 
adapted to receive a memory, the memory comprising: 

a first bank of Burst access memory coupled to the memory 
controller to receive a plurality of access control signals; and 

a second bank comprised of one of either Extended Data Out 
memory or Fast Page Mode memory, coupled to the memory controller to 
receive the plurality of access control signals, wherein the memory 
controller drives the access control signals in a first mode to provide access 
to said first bank, and the memory controller drives the access control 
signals in a second mode to provide access to said second bank. 



7. The system according to claim 6, wherein: 



said second bank is interchangeably one of either Extended 
Data Out memory or Fast Page Mode memory. 

8. A system adapted to receive a memory, the system comprising a 
memory controller, the memory comprising: 

a first bank and a second bank, wherein the first bank and the second 
bank are independently interchangeably one of either a first type of memory 
or a second type of memory, and the memory controller controls access of 
the first bank in accordance with a first set of requirements for the first type 
and the second bank in accordance with a second set of requirements for the 
second type. 



9. A method of determining a type of memory present in a system, 
comprising: 

a) applying a column address to a memory; 

b) writing a sequence of data patterns to the memory in a burst mode; 

c) reading data from the memory in an Extended Data Out page 
mode beginning at the column address and advancing the column address 
with each Extended Data Out page mode cycle; and 

d) comparing data read from the memory with data written to the 
memory to determine the type of memory present. 



10. A method of determining a type of memory present in a system, 
comprising: 

a) writing a sequence of data patterns to a memory in a page mode to 
a sequence of column addresses; 

b) reading data from the memory in a burst mode; and 

c) comparing data read from the memory with data written to the 
memory to determine the type of memory present. 

11. A method of determining a type of memory present in a system, 
comprising: 

a) writing a sequence of data patterns to a memory in a burst mode; 

b) reading data from the memory in a burst mode; and 



c) comparing data read from the memory with data written to the 
memory to determine the type of memory present. 

12, In a system adapted to receive one of a plurality of different memory 
types, a method of determining a type of memory present, comprising: 

a) writing a sequence of data pattems to a memory in a page mode to 
a first sequence of column addresses; 

b) reading data from the memory in a page mode from a second 
sequence of column addresses; and 

c) comparing data read from the memory with data written to the 
memory to determine the type* of memory present. 



1 3 . The method according to claim 1 2 wherein: 

the first sequence and the second sequence are identical. 

14. The method according to claim 12 wherein: 

data read from the memory is sampled at a transition time of a 
column address strobe. 

1 5 . The method according to claim 1 2wherem: 

data read from the memory is sampled during a high period of a 
column address strobe. 



16. A method of detennining a type of memory present in a system, 
comprising: 

a) writing a sequence of data patterns to a memory in a plurality of 
single discrete write cycles to a plurality of addresses in a first address 
order; 

b) reading data from the plurality of addresses; and 

c) comparing data read from the memory with data written to the 
memory to determine the type of memory present 

1 7. The method according to claim 1 6 wherein: 

said step of reading data is performed in a Burst Extended Data Out 

mode. 



1 8 . The method according to claim 1 6 wherein: 



said step of reading data is performed in a second address order. 



19. In a system having a memory of a type which is undetermined, a 
method for determining the type of memory, comprising: 

a) accessing the memory with control signals in a first control signal 
format which is incompatible with the memory; and 

b) accessing the memory with the control signals in a second control 
signal format which is compatible with the memory. 



20. A method of determining a type of a memory present in a system in 
response to a system initialization condition, the method comprising steps 
of: 



a) storing a data value in the memory at an address; 



b) accessing the memory in a read format at the address; 



c) sampling a data output of the memory at two or more instances 
during said step of accessing; and 



d) comparing the data output, sampled during said step of sampling, 
with the data value to determine the type of memory present. 



21. A method of determining a type of a memory, the memory 
comprising a plurality of memory cells, the method comprising steps of: 

a) writing a data pattern to a first cell of the memory at a first row 
address and a first column address in a DRAM early write access cycle 
format; 

b) accessing the first cell and a second cell of the memory by 
applying at least two column address strobes in a page mode read format, a 
first column address strobe being applied in conjunction with the first 
column address, and a second column address strobe being applied in 
conjunction with a second column address; 

c) sampling a data output from the memory subsequent to the second 
column address strobe being applied; and 

d) comparing the data output from the memory with the data pattern 
to determine the type of memory. 



22. The method of claim 21, further comprising a step of: 

selecting a set of comparison cells from the plurality of memory cells, 
said set comprising the first cell and the second cell, wherein said step of 
selecting a set is performed prior to said step of writing a data pattem. 

23. The method of claim 22, further comprising steps of: 

a) programming a memory controller to access the memory in an 
access mode determined by the type of memory present; 

b) writing, according to the access mode, a functional verification 
data pattem to all cells of the plurality of memory cells; 



c) reading data, according to the access mode, from all cells; and 



d) comparing data read to the functional verification data pattern to 
verify functionality of each memory cell of the memory. 

24, A method of determining a type of memory, comprising: 

a) writing a first data pattem and a second data pattem to a first and a 
second address of a memory in a page mode early write cycle format; 

b) reading from the memory in a Burst Extended Data Out format 
comprising at least three high to low transitions of a column address strobe 
signal; 

c) driving the column address strobe signal to a high level 
subsequent to said step of reading; 



d) sampling a memory data output pattern subsequent to said step of 
driving; and 

e) determining the type of memory dependent on the memory data 
output pattem. 

25. A method to increase performance of a computer system, comprising: 

a) replacing a first memory comprised of Extended Data Out type 
memory devices, with a second memory comprised of Burst Extended Data 
Out type memory devices; and 

b) reinitializing the computer system to enable the computer system 
to determine a type of memory present, and to program a memory controller 
to control access of the second memory at a higher data access rate than the 
first memory. 
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SYSTEM ADAPTED TO RECEIVE MULTIPLE MEMORY TYPES, AND 
METHOD FOR DETERMINING A TYPE OF MEMORY PRESENT 



ABSTRACT 



A system is capable of receiving Fast Page mode, Extended Data Out 
mode, Burst Extended Data Out mode, or a combination of these memory 
devices. A method of determining the type of memory present allows the 
system to adjust internal memory access signals in accordance with the type 

10 of memory installed. The system may be shipped with a first type of 
memory, and then upgraded to a second type of memory by the user to 
improve overall system performance. A first bank of memory may be of a 
first type, and a second bank may be of another t5^e. The user may make 
cost versus performance decisions when upgrading memory types or 

15 capacities. 
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